<template>
  <div class="dashboard-container">
    <div class="app-container">
      <el-card>
        <upload-excel :before-upload="beforeUpload" :on-success="onSuccess" />
      </el-card>
    </div>
  </div>
</template>

<script>
import { formatExcelDate } from '@/utils'
import { importEmployee } from '@/api/employees'
export default {
  name: 'Excel',
  methods: {
    // 将表格中的数据进行格式化
    transExcel(results) {
      const userRelations = {
        '入职日期': 'timeOfEntry',
        '手机号': 'mobile',
        '姓名': 'username',
        '转正日期': 'correctionTime',
        '工号': 'workNumber',
        '部门': 'departmentName',
        '聘用形式': 'formOfEmployment'
      }
      return results.map(item => {
        // 保存处理完成后每一项的值, 英文 key
        const obj = {}

        // 获取每一项所有的key ,中文的
        const contentKeys = Object.keys(item)

        contentKeys.forEach(key => {
          // 获取中文 key 对应的英文 key
          const transKey = userRelations[key]

          // 判断是否是日期
          if (transKey === 'timeOfEntry' || transKey === 'correctionTime') {
            // 将日期转换成时间戳
            obj[transKey] = new Date(formatExcelDate(item[key]))
          } else {
            obj[transKey] = item[key]
          }
        })
        return obj
      })
    },

    // 上传之前对文件的校验
    beforeUpload(file) {
      return true
    },

    // 上传成功后的处理
    async onSuccess({ header, results }) {
      const arr = this.transExcel(results)
      const res = await importEmployee(arr).catch(err => err)
      if (!res.success) return
      this.$router.back()
      this.$message.success('操作成功')
    }
  }
}
</script>

<style lang="scss" scoped></style>
